# CpE111 Introduction to Computer Engineering

Dr. Minsu Choi
CH 8: Memory Elements & Arrays



#### **Definition**

- A memory element is a circuit that can hold the value of a binary variable as required by the system.
- 3 modes: write, hold and read.

I type The Continue of the content o

### **Memory Types**

- RAM (Random Access Memory): read/write can be done. Loose contents when the power supply is disconnected.
- ROM (Read-Only Memory): Information is permanently stored. Only read operation can be done.
- Variations:
  - PROM (Programmable ROM) write procedure requires a special electronics setup.
  - Flash: holds contents even though the power supply is disconnected.
  - Registers: commonly used for fast internal storage.
     Each resister can usually hold one word.

#### **Latches**

■ A latch is a logic element that can follow data variations and transfer these changes to an output line.



- It is transparent in that the output Q(z) follows changes at the input at least part of the time.
- The storage is achieved using a bi-stable circuit, in which either Q=0 or Q=1 can be held in the cell.

### SR Latch (Set-Reset Latch)

■ A transparent bi-stable element that is sensitive to changes in the inputs.

uputs +R Q outputs

- Set (S) operation: the output is forced to a value of Q = 1.
- Reset (R) operation: the output is forced to a value of Q = 0.
- There are two different ways to implement: NOR-based and NAND-based.

### NOR-Based SR Latch Implementation

- Two cross-coupled NOR gates used.
- Feedback interconnects used to retain stored logic value.
- 0 to 1 to 0 transition at S sets Q.
- 0 to 1 to 0 transition at R resets Q.
- S=0 and R=0 to hold the current value of Q.
- S=1 and R=1 case is not used.



| (a) | Logic | diagram |
|-----|-------|---------|
|-----|-------|---------|

| S | R | Q | Q | Operation                 |
|---|---|---|---|---------------------------|
| 0 | 0 | Q | ē | Hold                      |
| Л | 0 | 1 | 0 | Set $(Q \rightarrow 1)$   |
| 0 | Л | 0 | 1 | Reset $(Q \rightarrow 0)$ |
| 1 | 1 | 0 | 0 | Not used                  |

(b) Function table

### **NAND-Based SR Latch Implementation**

- Two cross-coupled NAND gates used.
- Feedback interconnects used to retain stored logic value.
- 1 to 0 to 1 transition at S sets Q.
- 1 to 0 to 1 transition at R resets Q.
- S=1 and R=1 to hold the current value of Q.
- S=0 and R=0 case is not used.



|                    | • |
|--------------------|---|
| (a) I agia diagram |   |

| S | R | Q | $\bar{Q}$ | Operation                 |
|---|---|---|-----------|---------------------------|
| 0 | 0 | 0 | 0         | Not used                  |
| 5 | 1 | 1 | 0         | Set $(Q \rightarrow 1)$   |
| 1 | Г | 0 | 1         | Reset $(Q \rightarrow 0)$ |
| 1 | 1 | Q | Q         | Hold                      |

(b) Function table

### **D** Latch

- Input D determines Q and /Q.
- An inverter can be added to the NORbased SR latch to implement a D latch.



When b=0,  $\bar{b}$  is put to the bottom NDR gate is 1. This forces the output Q=0.  $\Rightarrow$  First stable state

When P=1, then the output of the upper NOR gate is forced to \$\overline{a} = 0. = 1 second stable state

### **Clocks and Synchronization**

 A clock is a control signal that periodically makes a transition from 0 to 1 then back to 0.

Ф(+) 1 (sec)

- It repeats same transition every T seconds.
- Recall f = 1/T and T = 1/f.
- **■** Ex)

T= Ins = 1 = 1/1ns = 1MHz

### **Clocked SR Latch**



- If Φ=0, then S Φ=0 & R Φ=0. So, the latch is in the hold state.
- If Φ=1, then set/reset operations can be done by S and R.
- This defines a "level triggered" or "levelsensitive" latch.

#### **Clocked D Latch**



- The input D is active only when Φ=1.
- If Φ=0, then it is in hold state.

### Master-Slave and Edge-Triggered Flip-Flops

- A flip-flop is non-transparent latch that is controlled by the clock.
- Master-slave structure is shown below.



### Why Master-Slave Structure Makes It "Non-Transparent"?



- Fig (a): The input to the master circuit is activated and the value of A is stored there. During the time, the slave is inactive (hold state) and cannot accept input.
- Fig (b): Then, the master is placed in a hold state while the slave is active. The value of A (not B!) is then accepted by the slave and is available at the output of the flip-flop giving Q=A.
- So, it is non-transparent (current output is not determined by the current input).



### **Timing Diagram**



- The value that is transferred to the slave circuit is the value that is in the master latch when the clock makes a transition from 0 to 1.
- So, DFF is "edge-sensitive".



Edge sometic best is morth to the sported when  $\phi = 0$ , but edge this government of PFF's wastainstainstance.

D = 0-1

### **Edge-Triggered**

■ Similar to edge-sensitive. However, it allows input data D to be loaded only when the clock is making a transition.

- The output Q is simply the value of input D delayed by one clock cycle -> Q(t+T)=D(t).
- The delay (=T) is an important aspect since we can store the present value for use during the next clock cycle.
- Then, how can we store a data bit for several clock cycles? => we must route the output Q back to the input D.









JIZ FF (Modified SR FF)







- A storage for n-bit binary word.
- Single-bit cells are cascaded to build multi-bit register.
- Mostly edge-triggered. Other control signals (e.g., LD) are not shown explicitly.
- Register symbol:



### **Shift Registers**

 Designed to move bits to neighboring cells as the clock pulses are applied.

(b) Clock cycles

Input sequence  $d_7 d_6 d_5 d_4 d_3 d_2 d_1 d_0$ (a) Contents cleared

First out.

### Continued,

| Time         | Input queue   | $d_7$ $d_6$ $d_5$ $d_4$ $d_3$ $d_2$ $d_1$ $d_0$ |
|--------------|---------------|-------------------------------------------------|
| <i>T</i> :   | 0,1,0,1,0,0,1 | + 1 <sup>+</sup>                                |
| 2 <i>T</i> : | 0,1,0,1,0,0   | -1+1+                                           |
| 3 <i>T</i> : | 0,1,0,1,0,    | - 0 - 1 - 1 -                                   |
| 4 <i>T</i> : | 0,1,0,1       | 0 0 1 1 1                                       |
| 5 <i>T</i> : | 0,1,0         | - 1 - 0 - 0 - 1 - 1 -                           |
| 6 <i>T</i> : | 0,1           | - 0 1 0 0 1 1 1                                 |
| <i>7T</i> :  | 0             | - 1 0 1 0 0 1 1 1                               |
| 8 <i>T</i> : |               | - 0 - 1 - 0 - 1 - 1 - 1 - 1                     |

### Shift Register w/ Parallel Load Capability



- 8-bit data word can be loaded/ accessed at the same time.
- SHR (shift right) & SHL (shift left) control signals are used to shift contents.

### **Example**

SHLL = 
$$NL_1 = 00111000 = 5610$$
  
 $SHL2 = 01110000 = 11210$ 

## SIR1=5 MR: = 00 000111 = 710. => SHRIM is to divide contents by 2 m.

### **Rotation Operations**

- ROR (Rotation Right) and ROL (Rotation Left): Rotation does not lose a bit if it is shifted out, but transfers it to the other side.
- Ex) N=10101100

$$ROR=1$$
  $NRI = 0[1010110]$ 
 $ROL=1$   $NLI = 0101100[]$ 

### Random Access Memory (RAM)

- Commonly found as the main system memory in a desktop computer unit.
- It provides the ability to store all of the important data needed to run the computer such as programs and the OS.
- There are two major types:
  - SRAM (Static RAM) for faster operation, but expensive.
  - DRAM (Dynamic RAM): cheap, large but slow.

#### **SRAM**

- Closed loop cascaded inverters can be used to build a SRAM cell.
- If WL=0, hold state (SWs open).
- If WL=1, read & write ops possible (SWs closed).







(Enable = 0 then Hold (Enable = 1 then r/w ops cambe from & R/W bit is well to Officensine read / write op.



### **Parity & Error Detection Codes**

- Even a single bit error can cause an entire program to crash -> reliability is critical.
- EDC (Error Detection Code) & ECC (Error-Correction Code) are used.
- Ex) Parity bit (the most simple EDC)

  Deven parity schene: Peren is Chosen to Make (B+ Peren)

  have an even # of 2 s ex) B = 01101101 Peren=)

  Codd Parity

  (B+ Podd) has an odd # of 1s.

  ex) B=11110000 then Podd=1.
- Parity bit generator



### **ROM (Read-Only Memory)**

- Memory array that used for permanent data storage (=non-volatile) => data remains even if the power supply is disconnected.
- Ex) 64x8b ROM



- The address word A<sub>5</sub>A<sub>4</sub>A<sub>3</sub>A<sub>2</sub>A<sub>1</sub>A<sub>0</sub> is sent to a row decoder.
- 2. The data word is send to the output circuits, which are activated by the Enable control.

### **DRAM (Dynamic RAM)**

- Can be built with much higher densities than SRAM cells.
- The descriptive adjective "Dynamic" reflects the fact that the contents of a cell will change in time during the hold state.
- DRAM cell is slower than SRAM cell. However, the cost per bit is much lower than SRAM cell -> attractive in system design where large arrays are required.
- Since many companies use their most advanced technology for making DRAMs, it is called "technology driver".

Acress
transistor

Storage capacity

@ source. So, hery high juterprotion is possible

### DRAM Operation Detail: Write Operation

- When WL=1, the nFET acts as a closed switch allowing write or read operation.
- To write to the cell:
  - Data voltage V<sub>D</sub> is applied to the data line D.
  - The resulting current charges the storage capacitor C<sub>S</sub> to the voltage level V<sub>S</sub>.

  - If  $V_S = V_0 = 0v$ , then  $Q_S = 0$  corresponding to a logic '0' value. If  $V_S = V_1$ , then a logic 1 charge.  $Q_S = C_S \times V_1$  is stored on the capacitor.

Vo - 109.10 V1 - 105:01

### **DRAM: Hold Operation**

- WL=0 for hold operation.
- The charge Q<sub>S</sub> would be held, since nFET is open.
- However, nFET cannot block all of the current flow.
- Even with a zero gate voltage, nFET admit a small "leakage current" I<sub>L</sub> that removes charge from the capacitor -> the charge Q<sub>S</sub> cannot be stored indefinitely -> logic 1 voltage will decay to 0v (logic 0) over the time.



(a) Circuit model

### **Hold Time Estimation**

 Suppose that we place a logic 1 voltage VS = V1 on the capacitor, and we wish to calculate the time that the voltage can be held on the cell when the nFET is open, so that we can refresh the stored logic 1 to keep it

so that we can refresh the stored logic 1 to keep it.

$$I_{L} = -\frac{d \Omega s}{dt} \rightarrow derivative of the charge over the time.$$

$$= -\frac{d V s}{dt} \qquad (since \Omega s = C s \cdot V s)$$

$$I_{tisused} since the charge is decreasing in time.$$

$$= -\left(\frac{C s}{I_{L}}\right) \cdot dV s$$

$$\Rightarrow \int_{0}^{t_{H}} dt = \left(-\frac{C s}{I_{L}}\right) \cdot \int_{V_{L}}^{V_{min}} dV s$$

$$\Rightarrow \int_{0}^{t_{H}} dt = \left(-\frac{C s}{I_{L}}\right) \cdot \int_{V_{L}}^{V_{min}} dV s.$$

Find the sides gives

this the "Hold time" > the time interval that the capacitor can maintain the voltage > V min.

(Umin is the lowest voltage level to represent

intime

19

(ex) Storge corrections  $C_s = 50 \text{ AF} = 50 \times 10^{-15} \text{ Fe}$ leackage current  $I_L = 1 \text{ PA} = 1 \times 10^{-12} \text{ A}$ Say (V, - V m m) = 1V. then  $t_H = \frac{50 \times 10^{-15}}{10^{-13}} = \frac{50 \times 10^{-3}}{10^{-13}} \Rightarrow 50 \text{ ms.}$   $\Rightarrow 50, \text{ olata must be refreshed in every 50 ms.}$ 

### Read & Refresh Operations

- WL=1 to turn on the nFET, which allows the current to flow to the bit line.
- Then, amp provides strengthened signal to output.
- In case of hold op, periodical read-out. amplification and rewrite needed -> called refresh.
- Say the max hold time is 10<sup>X</sup>-3sec. Then, the min refresh frequency is:





So, enclosed must be betheshed at 1000112 frequery, min.

### Program Completed

University of Missouri-Rolla

© 2003 Curators of University of Missouri

UNIVERSITY OF MISSOURI-ROLLA